/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: 17655
 * Date: 2025-02-08
 * Time: 23:22
 */
public class test2 {
    /**
     * LeetCode 238  除自身以外的数组的乘积
     */

    // 本题思路是除开自身的乘积，那就以自己为界限，计算自己的前缀乘积和后缀乘积
    public int[] productExceptSelf(int[] nums) {
        int n = nums.length;
        int []f=new int[n];
        int []g=new int[n];
        f[0]=1;
        g[n-1]=1;
        for(int i=1;i<n;i++){
            f[i] = f[i-1]*nums[i-1];
        }
        for(int i = n-2;i>=0;i--){
            g[i] = g[i+1]*nums[i+1];
        }
        int []ret = new int[n];
        for(int i=0;i<n;i++){
            ret[i]  = f[i]*g[i];
        }
        return ret;
    }
}
